package com.aaa.power.service;

import com.aaa.common.util.Result;
import com.aaa.power.entity.Role;

import java.util.List;

/**
 * 角色信息表(Role)表服务接口
 *
 * @author makejava
 * @since 2020-11-10 13:52:31
 */
public interface RoleService {

    /**
     * 通过ID查询单条数据
     *
     * @param roleId 主键
     * @return 实例对象
     */
    Role queryById(Integer roleId);

    /**
     * 根据角色id查询所有权限
     * @param roleId
     * @return
     */
    List<Integer> queryByIdToMenu(Integer roleId);

    /**
     * 分页和模糊查询
     * @param pageNo
     * @param pageSize
     * @param role
     * @return
     */
    Result queryPageByParam(Integer pageNo,Integer pageSize,Role role);

//    /**
//     * 查询多条数据
//     *
//     * @param offset 查询起始位置
//     * @param limit  查询条数
//     * @return 对象列表
//     */
//    List<Role> queryAllByLimit(int offset, int limit);

    /**
     * 根据角色id和菜单id给角色分配权限
     * @return
     */
    Integer insertByIdToMenus(Integer roleId,String menuIds);
    /**
     * 新增数据
     *
     * @param role 实例对象
     * @return 实例对象
     */
    Role insert(Role role);
    /**
     * 修改数据
     *
     * @param role 实例对象
     * @return 实例对象
     */
    Role update(Role role);

    /**
     * 通过主键删除数据
     *
     * @param roleId 主键
     * @return 是否成功
     */
    boolean deleteById(Integer roleId);

    /**
     * 通过实体作为筛选条件查询
     *
     * @param role 实例对象
     * @return 对象列表
     */
    List<Role> queryAll(Role role);
}